Optimal template for change content via XMLHTTPRequest with JQuery,PHP,SQL [closed]

Posted by B.F. on Stack Overflow See other posts from Stack Overflow or by B.F.
Published on 2012-10-11T11:44:12Z Indexed on 2012/10/12 3:37 UTC
Read the original article Hit count: 175

Filed under:
|
|
|

This is my method to handle XMLHTTPRequests.

Avoids mysql request, foreign access, nerves user, double requests.

Event Diagram

jquery

var allow=true;
var is_loaded="";
$(document).ready(function(){
....
$(".xx").on("click",functio(){
         if(allow){
           allow=false;
           if(is_loaded!="that"){
             $.post("job.php", {job:"that",word:"aaa",number:"123"},function(data){
               $(".aaa").html(data);
               is_loaded="that";
               });
             }
           setTimeout(function(){allow=true},500);
           }
....
});

job.php

<?PHP
ob_start('ob_gzhandler');
if(!isset($_SERVER['HTTP_X_REQUESTED_WITH']) or strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) != 'xmlhttprequest')exit("bad boy!");
if($_POST['job']=="that"){
  include "includes/that.inc;
  }
elseif($_POST['job']==
   ....
ob_end_flush();
?>

that.inc

if(!preg_match("/\w/",$_POST['word'])exit("bad boy!");
if(!is_numeric($_POST['number'])exit("bad boy!");
//exclude more.
$path="temp/that_".$row['word']."txt";
if(file_exists($path) and filemtime("includes/that.inc")<$filemtime($path)){
  readfile($path);
  }
else{
  include "includes/openSql.inc";
  $call=sql_query("SELECT * FROM that WHERE name='".mysql_real_escape_string($_POST['word'])."'");
  if(!$call)exit("ups");
  $out="";
  while($row=mysql_fetch_assoc($call)){
       $out.=$_POST['word']." loves the color ".$row['color'].".<br/>";
       }
  echo $out;
  $fn=fopen($path,"wb");
  fputs($fn,$out);
  fclose($fn);
  }

if something change at the database, you just have to delete involved files. Hope it was English.

© Stack Overflow or respective owner

Related posts about php

Related posts about jQuery